翻訳と辞書
Words near each other
・ Division of Bowman
・ Division of Braddon
・ Division of Braddon (state)
・ Division of Bradfield
・ Division of Brand
・ Division of Brisbane
・ Division of Bruce
・ Division of Burke
・ Division of Burke (1949–55)
・ Division of Burke (1969–2004)
・ Division of Calare
・ Division 39
・ Division 4
・ Division 7A dividend
・ Division algebra
Division algorithm
・ Division Avenue High School
・ Division Avenue–Plaster Creek Bridge
・ Division bell
・ Division bell (disambiguation)
・ Division bench
・ Division by two
・ Division by zero
・ Division by Zero (album)
・ Division by zero (disambiguation)
・ Division Day
・ Division Films
・ Division for Planetary Sciences
・ Division for Social Policy and Development
・ Division general (Bosnia)


Dictionary Lists
翻訳と辞書 辞書検索 [ 開発暫定版 ]
スポンサード リンク

Division algorithm : ウィキペディア英語版
Division algorithm

A division algorithm is an algorithm which, given two integers N and D, computes their quotient and/or remainder, the result of division. Some are applied by hand, while others are employed by digital circuit designs and software.
Division algorithms fall into two main categories: slow division and fast division. Slow division algorithms produce one digit of the final quotient per iteration. Examples of slow division include restoring, non-performing restoring, non-restoring, and SRT division. Fast division methods start with a close approximation to the final quotient and produce twice as many digits of the final quotient on each iteration. Newton–Raphson and Goldschmidt fall into this category.
Discussion will refer to the form N/D = (Q, R), where
* ''N'' = Numerator (dividend)
* ''D'' = Denominator (divisor)
is the input, and
* ''Q'' = Quotient
* ''R'' = Remainder
is the output.
==Division by repeated subtraction==
The simplest division algorithm, historically incorporated into a greatest common divisor algorithm presented in Euclid's ''Elements'', Book VII, Proposition 1, finds the remainder given two positive integers using only subtractions and comparisons:

while N ≥ D do
N := N - D
end
return N

The proof that the quotient and remainder exist and are unique, described at Euclidean division, gives rise to a complete division algorithm using additions, subtractions, and comparisons:

function divide(N, D)
if D = 0 then error(DivisionByZero) end
if D < 0 then (Q,R) := divide(N, -D); return (-Q, R) end
if N < 0 then
(Q,R) := divide(-N, D)
if R = 0 then return (-Q, 0)
else return (-Q - 1, D - R) end
end
-- At this point, N ≥ 0 and D > 0
Q := 0; R := N
while R ≥ D do
Q := Q + 1
R := R - D
end
return (Q, R)
end

This procedure always produces R ≥ 0. Although very simple, it takes Ω(Q) steps, and so is exponentially slower than even slow division algorithms like long division. It is useful if Q is known to be small (being an output-sensitive algorithm), and can serve as an executable specification.

抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)
ウィキペディアで「Division algorithm」の詳細全文を読む



スポンサード リンク
翻訳と辞書 : 翻訳のためのインターネットリソース

Copyright(C) kotoba.ne.jp 1997-2016. All Rights Reserved.